(2) Japanese Patent Application Laid-Open No. JP8-115206(1996)
"Floating Point Number Operation Device"

The following is an extract relevant to the present application.

5

10

A floating point number operation device including a means for adding three selecting circuits, three shifters, a complement circuit, and two data buses and providing an add/subtract circuit with an output of a multiply/divide normalization circuit by the first two bits thereof, a means for complementing an adder/subtracter adder circuit input data, and a means for bit shifting the adder/subtracter adder circuit input data, an adder/subtracter adder circuit result and an adder circuit overflow to be returned to the adder/subtracter adder circuit input again.

#### (19)日本国特許庁(JP)

## (12) 公開特許公報(A)

#### (11)特許出願公開番号

### 特開平8-115206

(43)公開日 平成8年(1996)5月7日

| (51) Int.Cl. <sup>6</sup> G 0 6 F 7/552 7/00 |      | 識別記号              |       | 庁内整理番号  | F I     | F I                 |                                    |      |          |  |  |  |  |
|----------------------------------------------|------|-------------------|-------|---------|---------|---------------------|------------------------------------|------|----------|--|--|--|--|
|                                              |      |                   | В     |         |         |                     |                                    |      |          |  |  |  |  |
|                                              | 7/52 | 3 1 0             | С     | 8323-5E | G06F    | 7/ 00               | 101                                | w    |          |  |  |  |  |
|                                              |      |                   |       |         | 審查請求    | 未請求                 | 請求項の数1                             | OL   | (全 14 頁) |  |  |  |  |
| (21)出願番号                                     |      | <b>特願平6-249</b> 0 | 89    |         | (71)出願人 | 0000051             | 社日立製作所                             |      |          |  |  |  |  |
| (22) 出願日                                     |      | 平成6年(1994         | 1) 10 | 月14日    | (71)出顧人 | 日立コンピュータエンジニアリング株式会 |                                    |      |          |  |  |  |  |
|                                              |      |                   |       |         | (72)発明者 | 灌口<br>神奈川           | 県泰野市堀山下<br>誠<br>県泰野市堀山下<br>エンジニアリン | 1 番地 | 日立コンピ    |  |  |  |  |
|                                              |      |                   |       |         | (74)代理人 | 弁理士                 | 小川勝男                               |      |          |  |  |  |  |
|                                              |      |                   |       |         | ·       |                     |                                    |      | 最終頁に続く   |  |  |  |  |

#### (54) 【発明の名称】 浮動小数点演算装置

#### (57)【要約】

【目的】 一般的な構成の浮動小数点演算装置に少量の 回路を付加することにより平方根演算器が可能となる浮 動小数点演算装置を提供する。

【構成】 3個の選択回路、3個のシフタ、補数回路、2本のデータバスを付加し、乗除算器正規化回路の出力を先頭から2ビットづつ加減算回路に供給する手段、加減算器加算回路入力データを補数化する手段、加減算器加算回路入力データと加減算器加算回路結果と加算回路オーバフローをビットシフトし再び加減算器加算回路入力に戻す手段を設けた浮動小数点演算装置。

【効果】 一般的な構成の浮動小数点演算装置に少量の 回路を付加することにより、非回復型平方根アルゴリズ ムによる平方根演算可能となる。



10

30

#### 【特許請求の範囲】

【請求項1】 加減算器と乗除算器とで構成される浮動 小数点演算装置において、前記乗除算器の正規化乗除数 レジスタの先頭2ビットを前記加減算器に転送する第1 データバスと、前記加減算器に転送した2ビットのデー タをシフトアウトして正規化乗除数レジスタにセットす るための第1の2ビット左シフタ及び選択回路と、前記 加減算器の加算回路の出力結果を2ビット左シフトする 第2の2ビット左シフタと、加減算器の補数回路の出 力、第2の2ピット左シフタの出力、及び乗除算器から の正規化乗除数レジスタの先頭2ビットをマージしたデ ータを選択する加減算器の補数結果レジスタ入力選択回 路と、加減算器の加算回路の結果の最上位ビットを加減 算器の桁合わせ結果レジスタ入力選択回路に転送する第 2 データバスと、加減算器の桁合わせ結果レジスタを 1 ビット左シフトする第3の1ビット左シフタと、加減算 器の桁合わせ回路の出力、第3の1ビット左シフタの出 力、及び加算回路の結果の最上位ビットをマージしたデ ータを選択する加減算器の桁合わせ結果レジスタ入力選 択回路と、加減算器の桁合わせ結果レジスタの出力を補 数化する桁合わせ結果のレジスタ出力補数回路と、加減 算器の補数結果レジスタと乗除算器の正規化乗除数レジ スタがゼロであるか否かを検出し、演算制御回路にゼロ 情報を送出するゼロ検出回路とを備えたことを特徴とし た浮動小数点演算装置。

#### 【発明の詳細な説明】

#### [0001]

【産業上の利用分野】本発明は、浮動小数点演算装置に関し、特に、既存の演算器回路を最大限に使用し、最小限の回路を付加することにより平方根演算を可能にする浮動小数点演算装置に関するものである。

#### [0002]

【従来の技術】従来、平方根の計算をハードウエアで実現する場合の手法として非回復型平方根アルゴリズムが知られている。これは、図9に示すように、加減算とシフトにより1回の開平ステップで1ビットの部分平方根を求める手法である。この手法による平方根演算については、例えば「コンピュータの高速演算方法」(堀越彌訳、近代科学社、昭和55年9月1日発行)第357頁から359頁に論じられている。

【0003】非回復型平方根アルゴリズムと冗長2進表現による平方根専用演算器を用い、1回の開平ステップで2ビットの部分平方根を求める発明が特開平3-296132公報に開示されている。

【0004】非回復型平方根アルゴリズムと類似している手法に回復型平方根アルゴリズムがある。これは、図10に示すように、減算とシフトにより平方根を求める手法である。この手法の平方根演算に関するものには、例えば特開平1-155435公報が挙げられる。特開平1-155435公報では回復型平方根アルゴリズム

を除算器上で実現した平方根演算器の発明について開示されている。これは回復型平方根アルゴリズムと高基数非回復型除算アルゴリズムの手法が類似しているため除算器に必要な回路を付加して平方根演算を実行可能にしたものである。前記図9及び図10において、2は加減算器、3は乗除算器、101は第2オペランドレジスタ、102は第1オペランドレジスタ、103は指合わせ回路、104は演算結果レジスタ、203は桁合わせ回路、204は補数回路、205は桁合わせ結果レジスタ、206は補数結果レジスタ、207は加算回路、208は加算中間結果レジスタ、207は加算回路、208は加算中間結果レジスタ、209、301、302は正規化回路、303は正規化乗除数レ

#### [0005]

除算回路である。

【発明が解決しようとする課題】従来技術の非回復型平方根アルゴリズムと冗長2進表現による発明は、1回の開平ステップで2ビットの部分平方根を求めることが可能であるため性能的には優れているが専用演算器を設けるためにハードウエア物量が増加してしまう。

ジスタ、304は正規化被乗除数レジスタ、305は乗

[0006] 科学技術計算の分野で用いられる平方根演算命令は、命令処理の高速化も要求されるが、命令の使用頻度が比較的少ないため専用演算器を設けることによる性能向上の効果よりハードウエア物量増加の悪影響の方が大きい場合がある。

【0007】従来技術の除算器上で平方根演算を実行する発明は、既存の演算器に平方根演算で必要な回路を付加するためハードウエア物量の増加は少量ですむが、高基数非回復型除算アルゴリズムと異なる除算アルゴリズムの除算器では実現不可能な場合がある。例えば、乗算器を用いた収束型除算器では実現不可能である。

[0008] 本発明の目的は、一般的な構成の浮動小数 点演算装置に少量の回路を付加することにより、平方根 演算が可能となる浮動小数点演算装置を提供することに ある。

[0009] 本発明の前記ならびにその他の目的及び新規な特徴は、本明細書の記載及び添付図面によって明らかになるであろう。

#### [0010]

(課題を解決するための手段)本願において開示された 発明のうち代表的なものの概要を簡単に説明すれば、以下のとおりである。

【0011】加減算器と乗除算器とで構成される浮動小数点演算装置において、前記乗除算器の正規化乗除数レジスタの先頭2ビットを前記加減算器に転送する第1データバスと、前記加減算器に転送した2ビットのデータをシフトアウトして正規化乗除数レジスタにセットするための第1の2ビット左シフタ及び選択回路と、前記加減算器の加算回路の出力結果を2ビット左シフトする第2の2ビット左シフタと、加減算器の補数回路の出力、

1.0

3

第2の2ビット左シフタの出力、及び乗除算器からの正規化乗除数レジスタの先頭2ビットをマージしたデータを選択する加減算器の補数結果レジスタ入力選択回路と、加減算器の加算回路の結果の最上位ビットを加減算器の桁合わせ結果レジスタ入力選択回路に転送する第2データバスと、加減算器の桁合わせ結果レジスタを1ビット左シフトする第3の1ビット左シフタと、加減算器の桁合わせ回路の出力、第3の1ビット左シフタの出力、及び加算回路の結果の最上位ビットをマージしたデータを選択する加減算器の桁合わせ結果レジスタの出力を補数化する桁合わせ結果のレジスタ出力補数回路と、加減算器の補数結果レジスタと乗除算器の正規化乗除数レジスタがゼロであるか否かを検出し、演算制御回路にゼロ情報を送出するゼロ検出回路とを備えたものである。

【0012】また、信頼性を確保した遅延時間の短縮は、前記の加減算器の加算回路の結果最上位ビットのかわりに、加減算器の加算回路の結果のオーバフローを加減算器の桁合わせ結果レジスタ入力選択回路の転送データパスとして用いること、及び加減算器の加算回路の結 20果最上位ビットの値と加算回路の結果オーバフローの値を比較する誤動作検出回路を設けたものである。

#### [0013]

【作用】前述の手段によれば、乗除算器の正規化乗除数 レジスタの先頭2ピットを加減算器に転送し、との加減 算器に転送した2ビットのデータを2ビット左シフタと 選択回路でシフトアウトして正規化乗除数レジスタにセ ットし、前記加減算器の加算回路の結果を2ビット左シ フトし、加減算器の補数回路の出力、加減算器の加算回 路の結果の2ビット左シフタ出力、乗除算器からの正規 化乗除数レジスタの先頭2ビットをマージしたデータを 選択し、加減算器の加算回路の結果の最上位ビットを加 減算器の桁合わせ結果レジスタ入力選択回路に転送し、 加減算器の桁合わせ結果レジスタを1ビット左シフト し、加減算器の桁合わせ結果レジスタ入力選択回路で加 減算器の桁合わせ回路出力、加減算器の桁合わせ結果レ ジスタの1ビット左シフタは出力、及び加算回路の結果 の最上位ビットをマージした(重ねた)データを選択 し、桁合わせ結果レジスタ出力補数回路で加減算器の桁 合わせ結果レジスタ出力を補数化し、ゼロ検出回路で加 減算器の補数結果レジスタと乗除算器の正規化乗除数レ ジスタがゼロであるか否かを検出し、演算制御回路にゼ 口情報を送出することにより、加減算器と乗除算器から 構成される一般的な浮動小数点演算装置に、3個のシフ タ、補数回路、2個のデータパスという少量の回路を付 加するだけで、平方根演算可能な浮動小数点演算装置を 実現することができる。

【0014】また、さらに加算回路の結果の最上位ビットとオーバフロー値を比較する誤動作検出回路を設ける ことにより加算回路のオーバフローの誤動作を検出する ことができる。

[0015]

[実施例]以下、本発明による実施例を図面を用いて詳細に説明する。

【0016】図1は、本発明による一実施例の浮動小数点演算装置の仮数部の概略構成を示すブロック図である。図1において、101は第2オペランドレジスタ、102は第1オペランドレジスタ、103は加減算器と乗除算器の演算結果を選択する選択回路、104は演算結果を格納する演算結果レジスタ、105は演算器全体の制御を行なう演算制御回路である。

【0017】201~209は、ロード命令や加減算命令を実行する加減算器の構成要素であり、201は指数小側の仮数データを選択する選択回路、202は指数大側の仮数データを選択する選択回路、203は指数小側仮数データの桁合わせを行なうシフタ、204は指数大側仮数データを真の減算時に補数化する補数回路、205は桁合わせ回路出力を保持する桁合わせ結果レジスタ、206は補数回路出力を保持する補数結果レジスタ、207は桁合わせデータと補数回路データを加算する加算回路、208は加算回路の結果を保持する加算中間結果レジスタ、209は加算中間結果データを正規化する正規化回路である。

[0018]301~305は、乗除算命令を実行する 乗除算器の構成要素であり、301は第2オペランドを 正規化する正規化回路、302は第1オペランドを正規 化する正規化回路、303は正規化回路301の出力を 保持する正規化乗除数レジスタ、304は正規化回路3 02の出力を保持する正規化被乗除数レジスタ、305 は正規化乗除数と正規化被乗除数レジスタ、305 は正規化乗除数と正規化被乗除数から乗除算結果を求め る乗除算回路である。401~411は、本発明により 浮動小数点演算装置に付加した平方根演算のための平方 根演算回路であり、401は正規化乗除数レジスタの値 を2ビット左シフトする第1の2ビット左シフタ、40 2は正規化回路301出力、第1の2ビット左シフタ4 01出力を選択する正規化乗除数レジスタ入力選択回路 である。

【0019】403は正規化乗除数レジスタ303に格納されたa2k+1とa2k+2を選択回路405に転送するデータバスである。404は加算回路207の出力Rkを2ビット左シフトする第2の2ビット左シフタである。405は補数回路204出力、データバス403、第2の2ビット左シフタ404の出力を選択する補数結果レジスタ入力選択回路である。

【0020】406は加算回路207のオーバフロービットを選択回路408に転送するデータバスである。407は桁合わせ結果レジスタ205に格納したq1~qk-1を1ビット左シフトする第3の1ビット左シフタである。408は桁合わせ回路203出力、加算回路207のオーバフローデータバス406、第3の1ビット左シ

10

フタ407の出力を選択する桁合わせ結果レジスタ入力 選択回路である。

【0021】409は桁合わせ結果レジスタ205の出力をqkの値により補数化する桁合わせ結果レジスタ補数回路である。410は補数結果レジスタ206、正規化乗除数レジスタ303に格納されているRkとa2k+1~anがゼロであることを検出するゼロ検出回路である。ゼロ検出回路410で検出されたゼロ情報は、演算制御回路105に転送され繰返し演算の終了条件に使われる。

【0022】411は平方根演算の繰返し演算時に加算回路207の結果の最上位ビットの値とオーバフローの値を比較する誤動作検出回路である。加算回路207の結果の最上位ビットとオーバフロー値が排他的でないとき誤動作報告を行なう。

【0023】一般的な浮動小数点演算装置の加算器は、仮数部7バイトにガードデジット0.5バイトを合わせた7.5バイト((1,0)~(8,3))の加減算を可能とするため7.5バイト幅のデータを処理できる。【0024】図2は、本実施例の前記正規化乗除数レジスタ入力選択回路402は、図2に示すように、平方根命令以外(乗除算命令)と平方根命令の初期設定時は正規化回路の出力を選択し、平方根命令の初期設定時は正規化回路の出力を選択し、平方根演算の繰返し演算時は、2ビット左シフタ401の値を選択する。2ビット左シフタ401と選択回路402により平方根演算時、正規化乗除数レジスタ303にはa2k+1~anの値を左詰めで格納できる。そのため選択回路405にはa2k+1~akを容易に供給できる。30

【0025】図3は、本実施例の前記補数結果レジスタ入力選択回路405の動作を説明するための図である。この補数結果レジスタ入力選択回路405は、図3に示すように、平方根命令以外(加減算、ロード命令)時は正規化回路の出力を選択し、平方根演算の初期設定時はデータバス403のa1、a2を選択する。平方根演算の繰返し演算時には、上位ビットに2ビット左シフタ404出力、下位ビットにはデータバス403のa2k+1、a2k+2を選択する。平方根演算でk>n+1が成立した場合の終了処理では丸め処理を行なうために、q57と同じ40ビット位置に1を立てるため0……0100を選択する。平方根演算のRk=0、かつa2k+1~a,n=0が成立した途中終了の場合の終了処理時はゼロを選択する。

【0026】図4は、前記桁合わせ結果レジスタ入力選択回路408の動作を説明するための図である。この桁合わせ結果レジスタ入力選択回路408は、図4に示すように、平方根命令以外(加減算、ロード命令)時は桁合わせ回路の出力選択し、平方根演算の初期設定時はゼロを選択する。平方根演算の繰返し演算時、終了処理時は上位ビットに1ビット左シフタ407の出力のq1~

q k-1を選択し、次のビットにはオーバフローパス40 6の q kを選択し、最下位の2ビットには0を選択す ス

[0027] 図5は、前記桁合わせ結果レジスタ補数回路409の動作を説明するための図である。この桁合わせ結果レジスタ補数回路は平方根命令以外(加減算、ロード命令)時、平方根演算の終了時は桁合わせ結果レジスタ出力を選択する。平方根演算の繰返し演算で q k=1時は桁合わせ結果レジスタの出力をビットごとに反転し、最下位の2ビットを1としたデータを選択する。平方根演算の繰返し演算で q k=0時は桁合わせ結果レジスタの出力の最下位の2ビットを1としたデータを選択する。

【0028】図6は、本実施例の平方根演算器で実行する平方根命令の処理手順を示すフローチャートであり、 長精度浮動小数点平方根命令の処理フローであるが、短 精度浮動小数点平方根命令の場合には被開平数と演算結 果の仮数が56ビットから24ビットに変わるだけである。

1 【0029】本実施例で演算する平方根命令は、図6に示すように、最初に、被開平数が正、ゼロ、負であるか調べる(ステップ601)。負の場合には平方根例外の割込みを報告する(ステップ606,607)。ゼロの場合には演算処理を行なわず演算結果をゼロにして終了する(ステップ608)。正の場合には被開平数を指数が偶数になる様に正規化する(ステップ602)。

[0030] これは次に行なう指数の演算処理(ステップ603)、すなわち、正規化した指数の値を2で割り 演算結果指数を求める処理(ステップ611)において 30 割り切れるよう、あらかじめ指数を偶数とする必要があ ることによる。仮数の演算処理(ステップ604)は仮 数平方根を求める処理(ステップ612)と丸め処理 (ステップ613)から構成される。

【0031】仮数平方根を求める処理(ステップ612)は非回復型平方根アルゴリズムで57ビットの平方根を求めることにより実現される。57ビットの平方根を求めるのは、その後に行なう丸め処理(ステップ613)のためで、演算結果より1ビット余分に平方根を求める。

0 [0032] 丸め処理(ステップ613)では、余分に 求めた最終ビットに1を加える。最後に、指数演算処理 と仮数演算処理の演算結果を結合した値が演算結果とな り(ステップ605)、平方根命令演算を終了する。 [0033]図7は、本実施例の浮動小数点演算装置の 動作を摸式的に示した図である。図7では、選択回路で 選択したデータがわかるように記述したため選択回路自 身の記述を省略した。

[0034] 平方根演算では、桁合わせ結果レジスタ2 05は、 $q1\sim qk00$  を格納するために使用し、補数結 果レジスタ206はRkを格納するために使用する。ま た、補数回路409の出力が(± Dk)となる。

【0035】初期設定動作を説明する。図7に示すように、最初に、第2オペランドレジスタ101に被開平数がセットされる。次に、正規化回路301で指数が偶数になるように、被開平数仮数部を正規化し、そのデータを正規化乗除数レジスタ303にセットする。次に、桁合わせ結果レジスタ205には0をセットし、補数結果レジスタ206には上位ビットを0とし最下位の2ビットには正規化乗除数レジスタ303の最上位の2ビットには正規化乗除数レジスタ303の最上位の2ビット(a1、a2)をセットする。

【0036】正規化乗除数レジスタ303は、a1 a2を加算器に転送すると、2ビット左シフタ402によりa1、a2をシフトアウトしデータa3~anを格納する。正規化乗除数レジスタ303の値はR0となる。とこまでが初期設定動作である。

【0037】次に、繰返し演算動作を説明する。桁合わせ結果レジスタ205にセットされている $q1\sim q$  kは q kの値に従い補数回路409で補数化し( $\pm$  Dk)とする。補数回路409での補数化は、先に説明した図5に示すように行なう。補数回路409の出力( $\pm$  Dk)は、補数結果レジスタ206にセットされているR kと加算回路207で加算する。

【0038】加算回路207の結果はRk+1であり、加算回路207のオーバフロー406はqk+1である。加算回路207の結果Rk+1は、2ビット左シフタ404でシフトされ、正規化乗除数レジスタ303の最上位2ビットa2k+1、a2k+2を最下位ビットに付加して補数結果レジスタ206にセットする。

【0039】正規化乗除数レジスタ303は、a2k+1、a2k+2を加算器に転送すると2ビット左シフタ402により、a2k+1、a2k+2をシフトアウトしデータa2k+3~anを格納する。加算回路207のオーバフロー206であるqk+1は、桁合わせ結果レジスタ205を1ビット左シフタ407でシフトしたq1~qk-1の下位ビットに付加して桁合わせレジスタ205にセットする。

【0040】誤動作検出回路411は、加算回路207の結果の最上位ビットとオーバフロー値を比較し、これらが排他的でないとき誤動作報告を行なう。ここまでが繰返し演算の1回分である。繰返し演算は1マシンサイクルで1回演算し、繰返し演算1回では1ビットのqkが求まる。繰返し演算をn回繰返しq1からqnを求める。本実施例の浮動小数点演算装置で演算する長精度平方根命令では57回繰返しq1からq57を求める。

[0041]次に、終了処理動作を説明する。終了動作はk>n+1(図7の非回復型平方根アルゴリズムではk>nまでだが、本実施例の浮動小数点演算装置で演算する平方根命令では1ビット余分にqkを求め、丸め処理を行なうためk>n+1とする)が成立した場合、及びR k=0、かつ a 2 k+1  $\sim a$  n=0 が成立した途中終了の場合がある。

[0043]次に、補数回路409は、桁合わせレジスタに格納されているq1~qn+1を素通りさせ、その出力と補数回路206の0……0100を加算回路207で加算する。207の加算結果は、加算中間結果レジスタ208にセットする。次に、加算中間結果レジスタ208にセットした値を正規化回路209でq1が最も左のビットに来るようにシフトし、qnより右のビットを切捨て演算結果レジスタにセットし演算を終了する。

【0044】Rk=0、かつa2k+1~an=0が成立した途中終了の場合は、最初に、補数結果レジスタ206にゼロを選択してセットする。次に、補数回路409は桁合わせレジスタに格納されているq1~qkを素通りさせ、その出力と補数回路206のゼロを加算回路207で加算する。加算回路207の加算結果は、加算中間結果レジスタ208にセットする。次に、加算中間結果レジスタ208にセットした値を正規化回路209でq1が最も左のビットに来るようにシフトし演算結果レジスタ104にセットし演算を終了する。

【0045】以上の説明からわかるように、本実施例に よれば、乗除算器の正規化乗除数レジスタの先頭2ビッ トを加減算器に転送し、この加減算器に転送した2ビッ トのデータを第1の2ピット左シフタ401及び選択回 路402でシフトアウトして正規化乗除数レジスタ30 3にセットし、前記加減算器の加算回路207の結果を 第2の2ビット左シフタ404で2ビット左シフトし、 加減算器の補数回路206の出力、加減算器の加算回路 207の結果を2ビット左シフトする第2の2ビット左 シフタ404の出力、乗除算器の正規化乗除数レジスタ 303の先頭2ビットをマージしたデータを選択し、加 減算器の加算回路207の結果の最上位ビットを加減算 器の桁合わせ結果レジスタ入力選択回路408に転送 し、加減算器の桁合わせ結果レジスタ205を第3の1 ビット左シフタ407で1ビット左シフトし、加減算器 の桁合わせ結果レジスタ入力選択回路408で、加減算 器の桁合わせ回路203の出力、第3の1ビット左シフ タ407の出力、及び加算回路207の結果の最上位ビ ットをマージしたデータを選択し、桁合わせ結果レジス タ205の出力の補数回路409で加減算器の桁合わせ 結果レジスタ205の出力を補数化し、ゼロ検出回路4 10で加減算器の補数結果レジスタ206と乗除算器の 正規化乗除数レジスタ303がゼロであるか否かを検出 し、演算制御回路105にゼロ情報を送出することによ り、加減算器と乗除算器から構成される一般的な浮動小 数点演算装置に、3個のシフタ、補数回路、2個のデー タバスという少量の回路を付加するだけで、平方根演算 50 可能な浮動小数点演算装置を実現することができる。

【0046】また、さらに加算回路の結果の最上位ビットとオーバフロー値を比較する誤動作検出回路を設ける ことにより加算回路オーバフローの誤動作を検出することができる。

【0047】図8は、本実施例の非回復型平方根アルゴリズム処理の手順を示すフローチャートである。

【0048】図8おいて、a2k+1~anは、図1の正規化乗除数レジスタ303に左詰めで格納され、anより右のビットには0を格納する。q1~qnは、図1の桁合わせ結果レジスタ205のビット(1,0)~(8,1)に右詰めで格納され、q1より左のビットには0が入る。Rkは図1の補数結果レジスタ206に右詰めで格納され、上位のビットには符号を格納する。

【0049】ステップ522のR k+1= R k+ D kまたは 512のR k+1= R k- D kの計算は、図1の加算回路2 07でR k+1= R k+ (± D k) と変形しておこなう。

(± D k) は、図1の補数回路409へ桁合わせ結果レジスタ205に格納のq1~q kを入力し作成する。q k = 0の時(± D k) は+ D kとなり、その値は(q1……q k11)とする。q k= 1の時(± D k) は- D kとなり、その値は(q1……q k01)を2の補数化した値(¬q1……¬q k11)とする。

【0050】平方根の繰返し演算時、加算回路207での計算が常に真の減算となることは、図8よりqk=0の時Rk+1=Rk+DkのRkは負であり、qk=1の時Rk+1=Rk-DkのRkは、正であることから明らかである。真の減算であるため加減算回路207の演算結果の最上位ビットがRk+1の符号を、オーバフロー(406)は、Rk+1の一符号を表す。Rk+1 $\geq$ 0の時qk+1=1、Rk+1<0の時qk+1=0となることによりオーバフロー406=qk+1となる。平方根の繰返し演算時は加算回路207の結果の最上位ビットのかわりにオーバフロー(406)を使用しても問題ない。

【0051】図8のステップ503と504によるRk=0、a2k+1~an=0の判定は、図1のゼロ検出回路410で行なう。ゼロ検出回路410で検出されたゼロ検出信号は、演算制御回路105に報告される。演算制御回路105はゼロ検出信号により平方根の繰返し演算を中止し終了処理を行なう。

【0052】図9は、一般的な浮動小数点演算装置の仮数部の概略構成を示すブロック図であり、2は加減算器、3は乗除算器、101は第2オペランドレジスタ、102は第1オペランドレジスタ、103,201,202は選択回路、104は演算結果レジスタ、203は桁合わせ回路、204は補数回路、205は桁合わせ結果レジスタ、206は補数結果レジスタ、207は加算回路、208は加算中間結果レジスタ、207は加算回路、208は加算中間結果レジスタ、209,301、302は正規化回路、303は正規化乗除数レジスタ、304は正規化被乗除数レジスタ、305は乗除算回路である。

【0053】図9に示すように、通常の加算回路の演算結果は、パリティにより誤動作の検出を行なっているが、オーバフローなどのキャリーは、誤動作の検出を行なっていない。平方根演算の繰返し演算時は加算回路結果の最上位ピット=加算回路のオーバフローが必ず成立することより、誤動作検出回路411は、加算回路の結果の最上位ピット=加算回路オーバフローの時、誤動作報告を行なう。

【0054】また、通常の加算回路は、その結果よりも 10 オーバフローなどのキャリを早く求めるよう回路を設計 する。そのため、加算回路207の結果の最上位ビット の符号を桁合わせ結果レジスタ入力選択回路に転送する かわりに、オーバフロー406を桁合わせ結果レジスタ 入力選択回路に転送した方が遅延時間を短くできる。以 上、本発明を実施例に基づき具体的に説明したが、本発 明は、前記実施例に限定されるものではなく、本発明の 要旨を逸脱しない範囲において、種々変更し得ることは 勿論である。

[0055]

20 【発明の効果】本願において開示された発明の代表的な ものによって得られる効果を簡単に説明すれば、以下の とおれてある。

[0056] 加減算器と乗除算器から構成される一般的な浮動小数点演算装置に3個のシフタ、補数回路、2個のデータバスという少量の回路を付加することにより、平方根演算可能な浮動小数点演算装置を実現することができる。

[0057] また、加算回路の結果の最上位ビットとオーバフロー値を比較する誤動作検出回路を設けることに 30 より、加算回路オーバフローの誤動作を検出することができる。

【図面の簡単な説明】

【図1】本発明による一実施例の浮動小数点演算装置の 仮数部の概略構成を示すブロック図である。

【図2】本実施例の正規化乗除数レジスタ入力選択回路の動作を説明するための図である。

【図3】本実施例の補数結果レジスタ入力選択回路の動作を説明するための図である。

【図4】本実施例の桁合わせ結果レジスタ入力選択回路 の動作を説明するための図である。

【図5】本実施例の桁合わせ結果レジスタ出力補数回路の動作を説明するための図である。

【図6】本実施例の浮動小数点演算装置で実行する浮動 小数点平方根命令の処理手順を示すフローチャートであ る

【図7】本実施例の浮動小数点演算装置の仮数部の動作 を摸式的に示した図である。

【図8】本実施例の非回復型平方根アルゴリズムの処理 手順を示すフローチャートである。

50 【図9】一般的な浮動小数点演算装置の概略構成を示す

11

ブロック図である。

【図10】従来の回復型平方根アルゴリズムの処理手順 を示すフローチャートである。

#### 【符号の説明】

2…加減算器、3…乗除算器、101…第2オペランドレジスタ、102…第1オペランドレジスタ、103,201,202,402,405,408…選択回路、104…演算結果レジスタ、105…演算制御回路、203…桁合わせ回路、204,409…補数回路、20\*

\*5…桁合わせ結果レジスタ、206…補数結果レジスタ、207…加算回路、208…加算中間結果レジスタ、209、301、302…正規化回路、303…正規化乗除数レジスタ、304…正規化被乗除数レジスタ、305…乗除算回路、401、404…2ビット左シフタ、403、406…データバス、407…1ビット左シフタ、410…ゼロ検出回路、411…誤動作検出回路。

12

【図1】



[図2]

# 図 2

|                      | 2       | 3   | 4    | 5   | 6   | 7     |     |     | <u>,                                     </u> |   |  |  |  |
|----------------------|---------|-----|------|-----|-----|-------|-----|-----|-----------------------------------------------|---|--|--|--|
| バイト位置 1<br>ビット位置 0-7 | 0-7     | 0-7 | 0-7  | 0-7 | 0-7 | 0-7   | 0   | 1   | 2                                             | 3 |  |  |  |
| 選択条件 選扔              | データ     |     |      |     |     | _     |     |     |                                               |   |  |  |  |
| 平方根演算命令以外            | 正規化回路出力 |     |      |     |     |       |     |     |                                               |   |  |  |  |
| 平方根演算命令 初期設定時        | 正規化回路出力 |     |      |     |     |       |     |     |                                               |   |  |  |  |
|                      | 授化乗降    | 数レジ | スタ左2 | ピット | シフト | 果(a2K | +1~ | an) | 0                                             | 0 |  |  |  |

[図3]

# 図 3

| バイト位置                           | 1                                  | 2      | 3   | 4   | 5   | 6   | 7   |   |   | <u> </u> |   |  |  |  |  |
|---------------------------------|------------------------------------|--------|-----|-----|-----|-----|-----|---|---|----------|---|--|--|--|--|
| ビット位置                           | 0-7                                | 0-7    | 0-7 | 0-7 | 0-7 | 0-7 | 0-7 | 0 | 1 | 2        | 3 |  |  |  |  |
| 選択条件                            | 選択データ                              |        |     |     |     |     |     |   |   |          |   |  |  |  |  |
| 平方根演算命令以外                       |                                    | 補数回路出力 |     |     |     |     |     |   |   |          |   |  |  |  |  |
| 平方根漢算命令<br>初期設定時                | ゼロ a1 a2                           |        |     |     |     |     |     |   |   |          |   |  |  |  |  |
| 繰り返し演算時                         | 加算回路出力左2ビットシフト結果(Rk-1) a2k+1 a2k+2 |        |     |     |     |     |     |   |   |          |   |  |  |  |  |
| 丸め終了処理時                         | ±□ 1 0                             |        |     |     |     |     |     |   |   |          |   |  |  |  |  |
| 途中終了処理時<br>(Rk=0 & a2k+1 ~an=0) | ₩D                                 |        |     |     |     |     |     |   |   |          |   |  |  |  |  |

【図4】

# 図 4

|                 | パイト位置                                        | 1        | 2   | 3   | 4   | 5   | 6   | 7   | 8       |  |  |  |
|-----------------|----------------------------------------------|----------|-----|-----|-----|-----|-----|-----|---------|--|--|--|
|                 | ビット位置                                        | 0-7      | 0-7 | 0-7 | 0-7 | 0-7 | 0-7 | 0-7 | 0 1 2 3 |  |  |  |
| 選択条件            |                                              | 選択を      | データ |     |     |     |     |     |         |  |  |  |
| 平方根演算命令以外       |                                              | 桁合わせ回路出力 |     |     |     |     |     |     |         |  |  |  |
| 平方根演算命令初期設定時    |                                              | 40       |     |     |     |     |     |     |         |  |  |  |
| 繰り返し演算<br>終了処理時 | 桁合わせ結果レジスタ左1ビットシフト結果(q1~qk-1)     qk   0   0 |          |     |     |     |     |     |     |         |  |  |  |

【図5】

終了処理時

|                  | パイト位置                                    | 1            | 2   | 3       | 4         | 5    | 6       | 7      | Ĺ,    | 8 | <u> </u> |   |  |
|------------------|------------------------------------------|--------------|-----|---------|-----------|------|---------|--------|-------|---|----------|---|--|
|                  | ビット位置                                    | 0-7          | 0-7 | 0-7     | 0-7       | 0-7  | 0-7     | 0-7    | 0     | 1 | 2        | 3 |  |
| 選択条件             |                                          | 選択を          | データ |         |           |      |         |        |       |   |          |   |  |
| 平方根演算命令以外        |                                          | 桁合わせ結果レジスタ出力 |     |         |           |      |         |        |       |   |          |   |  |
| 平方根演算命令<br>繰り返し演 | 一(桁合わせ結果レジスタ出力ビット(1,0)~(8,1)(q1~qk)) 1 1 |              |     |         |           |      |         |        |       |   |          |   |  |
| 繰り返し演            | (桁合わせ結果レジスタ出力ピット(1,0)~(8,1)(q1~qk)) 1 1  |              |     |         |           |      |         |        |       |   |          |   |  |
|                  |                                          |              |     | - ^ + 1 | 1 ## FB 1 | 2577 | 7 LLI - | 1010-0 | r 0 0 | 7 |          |   |  |

【図6】



【図7】



【図8】



【図9】



【図10】

### 図10



フロントページの続き

#### (72)発明者 増田 好徳

神奈川県秦野市堀山下1番地 日立コンピュータエンジニアリング株式会社内

### (72)発明者 髙橋 千秋

神奈川県秦野市堀山下1番地 日立コンピュータエンジニアリング株式会社内